//和用户相关的状态管理

import { createSlice } from '@reduxjs/toolkit'
import { request } from '@/utils'

const userStore = createSlice({
  name: 'user',
  //数据状态
  initialState: {
    token: ''
  },
  //同步修改方法
  reducers: {
    setToken(state,action) {
      state.token = action.payload
    }
  }
})

//解构出actionCreater

const { setToken } = userStore.actions

//获取reducer函数
const userReducer = userStore.reducer

//异步代码 完成登录获取token

const fetchLogin = (loginForm) => {
  return async (dispatch) => {
    //1.发送异步请求,已配置根目录，()中放相对目录
    const res = await request.post('/authorizations',loginForm)
    //2.提交同步action方法进行token的存入
    dispatch(setToken(res.data.token))
  }
}

export { setToken, fetchLogin }

export default userReducer